CVE-2024-25619
Destroying OAuth Applications doesn't notify Streaming of Access Tokens being destroyed in mastodon
Description
Mastodon is a free, open-source social network server based on ActivityPub. When an OAuth Application is destroyed, the streaming server wasn't being informed that the Access Tokens had also been destroyed, this could have posed security risks to users by allowing an application to continue listening to streaming after the application had been destroyed. Essentially this comes down to the fact that when Doorkeeper sets up the relationship between Applications and Access Tokens, it uses a `dependent: delete_all` configuration, which means the `after_commit` callback setup on `AccessTokenExtension` didn't actually fire, since `delete_all` doesn't trigger ActiveRecord callbacks. To mitigate, we need to add a `before_destroy` callback to `ApplicationExtension` which announces to streaming that all the Application's Access Tokens are being "killed". Impact should be negligible given the affected application had to be owned by the user. None the less this issue has been addressed in versions 4.2.6, 4.1.14, 4.0.14, and 3.5.18. Users are advised to upgrade. There are no known workaround for this vulnerability.
INFO
Published Date :
Feb. 14, 2024, 9:15 p.m.
Last Modified :
Dec. 18, 2024, 10:22 p.m.
Remotely Exploit :
Yes !
Source :
[email protected]
CVSS Scores
| Score | Version | Severity | Vector | Exploitability Score | Impact Score | Source | 
|---|---|---|---|---|---|---|
| CVSS 3.1 | LOW | [email protected] | ||||
| CVSS 3.1 | MEDIUM | [email protected] | 
References to Advisories, Solutions, and Tools
                                            Here, you will find a curated list of external links that provide in-depth
                                            information, practical solutions, and valuable tools related to
                                            CVE-2024-25619.
                                        
CWE - Common Weakness Enumeration
            While CVE identifies
            specific instances of vulnerabilities, CWE categorizes the common flaws or
            weaknesses that can lead to vulnerabilities. CVE-2024-25619 is
            associated with the following CWEs:
        
Common Attack Pattern Enumeration and Classification (CAPEC)
Common Attack Pattern Enumeration and Classification
            (CAPEC)
            stores attack patterns, which are descriptions of the common attributes and
            approaches employed by adversaries to exploit the CVE-2024-25619
            weaknesses.
We scan GitHub repositories to detect new proof-of-concept exploits. Following list is a collection of public exploits and proof-of-concepts, which have been published on GitHub (sorted by the most recently updated).
Results are limited to the first 15 repositories due to potential performance issues.
			The following list is the news that have been mention
			CVE-2024-25619 vulnerability anywhere in the article.
		
                The following table lists the changes that have been made to the
                CVE-2024-25619 vulnerability over time.
            
Vulnerability history details can be useful for understanding the evolution of a vulnerability, and for identifying the most recent changes that may impact the vulnerability's severity, exploitability, or other characteristics.
- 
                            Initial Analysis by [email protected]Dec. 18, 2024 Action Type Old Value New Value Added CVSS V3.1 NIST AV:N/AC:L/PR:L/UI:N/S:U/C:L/I:N/A:N Added CWE NIST CWE-613 Added CWE NIST CWE-672 Added CPE Configuration OR *cpe:2.3:a:joinmastodon:mastodon:*:*:*:*:*:*:*:* versions up to (excluding) 3.5.18 *cpe:2.3:a:joinmastodon:mastodon:*:*:*:*:*:*:*:* versions from (including) 4.0.0 up to (excluding) 4.0.14 *cpe:2.3:a:joinmastodon:mastodon:*:*:*:*:*:*:*:* versions from (including) 4.1.0 up to (excluding) 4.1.14 *cpe:2.3:a:joinmastodon:mastodon:*:*:*:*:*:*:*:* versions from (including) 4.2.0 up to (excluding) 4.2.6 Changed Reference Type https://github.com/mastodon/mastodon/commit/68eaa804c9bafdc5f798e114e9ba00161425dd71 No Types Assigned https://github.com/mastodon/mastodon/commit/68eaa804c9bafdc5f798e114e9ba00161425dd71 Patch Changed Reference Type https://github.com/mastodon/mastodon/commit/68eaa804c9bafdc5f798e114e9ba00161425dd71 No Types Assigned https://github.com/mastodon/mastodon/commit/68eaa804c9bafdc5f798e114e9ba00161425dd71 Patch Changed Reference Type https://github.com/mastodon/mastodon/security/advisories/GHSA-7w3c-p9j8-mq3x No Types Assigned https://github.com/mastodon/mastodon/security/advisories/GHSA-7w3c-p9j8-mq3x Vendor Advisory Changed Reference Type https://github.com/mastodon/mastodon/security/advisories/GHSA-7w3c-p9j8-mq3x No Types Assigned https://github.com/mastodon/mastodon/security/advisories/GHSA-7w3c-p9j8-mq3x Vendor Advisory 
- 
                            CVE Modified by af854a3a-2127-422b-91ae-364da2661108Nov. 21, 2024 Action Type Old Value New Value Added Reference https://github.com/mastodon/mastodon/commit/68eaa804c9bafdc5f798e114e9ba00161425dd71 Added Reference https://github.com/mastodon/mastodon/security/advisories/GHSA-7w3c-p9j8-mq3x 
- 
                            CVE Modified by [email protected]May. 14, 2024 Action Type Old Value New Value 
- 
                            CVE Received by [email protected]Feb. 14, 2024 Action Type Old Value New Value Added Description Mastodon is a free, open-source social network server based on ActivityPub. When an OAuth Application is destroyed, the streaming server wasn't being informed that the Access Tokens had also been destroyed, this could have posed security risks to users by allowing an application to continue listening to streaming after the application had been destroyed. Essentially this comes down to the fact that when Doorkeeper sets up the relationship between Applications and Access Tokens, it uses a `dependent: delete_all` configuration, which means the `after_commit` callback setup on `AccessTokenExtension` didn't actually fire, since `delete_all` doesn't trigger ActiveRecord callbacks. To mitigate, we need to add a `before_destroy` callback to `ApplicationExtension` which announces to streaming that all the Application's Access Tokens are being "killed". Impact should be negligible given the affected application had to be owned by the user. None the less this issue has been addressed in versions 4.2.6, 4.1.14, 4.0.14, and 3.5.18. Users are advised to upgrade. There are no known workaround for this vulnerability. Added Reference GitHub, Inc. https://github.com/mastodon/mastodon/security/advisories/GHSA-7w3c-p9j8-mq3x [No types assigned] Added Reference GitHub, Inc. https://github.com/mastodon/mastodon/commit/68eaa804c9bafdc5f798e114e9ba00161425dd71 [No types assigned] Added CWE GitHub, Inc. CWE-672 Added CWE GitHub, Inc. CWE-613 Added CVSS V3.1 GitHub, Inc. AV:N/AC:H/PR:L/UI:N/S:U/C:L/I:N/A:N 
Vulnerability Scoring Details
Base CVSS Score: 4.3
Exploit Prediction
EPSS is a daily estimate of the probability of exploitation activity being observed over the next 30 days.
0.36 }} -0.02%
score
0.57631
percentile
 
                         
                         
                         
                                             
                                            